﻿using System;
using System.Collections.Generic;
using System.Linq;
using Controller2.BLL;

namespace Controller2.Models.ViewModels
{
    public class VeiculoViewModel
    {
        public int ID { get; set; }
        public string Nome { get; set; }
        public string Categoria { get; set; }

        public IEnumerable<VeiculoViewModel> Listar(ControllerBDModelContainer db, string texto, int filtro)
        {
            IEnumerable<VeiculoViewModel> veic;
            int codigo = 0;
            if (filtro == 1)
            {
                if (!Int32.TryParse(texto, out codigo))
                {
                    filtro = 0;
                    texto = "";
                }
            }
            if (string.IsNullOrWhiteSpace(texto) || texto.Equals("Digite sua pesquisa"))
            {
                filtro = 0;
                texto = "";
            }
            switch (filtro)
            {
                default:
                    veic = from v in VeiculoBll.GetAllVeiculos(db)
                           orderby v.IdVeiculo
                           select new VeiculoViewModel
                           {
                               ID = v.IdVeiculo,
                               Nome = v.Nome,
                               Categoria = v.Categoria
                           };
                    break;
                case 1:
                    veic = from v in VeiculoBll.GetAllVeiculos(db)
                           orderby v.IdVeiculo
                           where v.IdVeiculo == codigo
                           select new VeiculoViewModel
                           {
                               ID = v.IdVeiculo,
                               Nome = v.Nome,
                               Categoria = v.Categoria
                           };
                    break;
                case 2:
                    veic = from v in VeiculoBll.GetAllVeiculos(db)
                           orderby v.IdVeiculo
                           where v.Nome.Contains(texto)
                           select new VeiculoViewModel
                           {
                               ID = v.IdVeiculo,
                               Nome = v.Nome,
                               Categoria = v.Categoria
                           };
                    break;
                case 3:
                    veic = from v in VeiculoBll.GetAllVeiculos(db)
                           orderby v.IdVeiculo
                           where v.Categoria.Contains(texto)
                           select new VeiculoViewModel
                           {
                               ID = v.IdVeiculo,
                               Nome = v.Nome,
                               Categoria = v.Categoria
                           };
                    break;
            }

			return veic.OrderBy(o => o.ID);
        }
    }
}